<template>
    <div>
        <div class="form-item form-item-style1">
            <div class="label-title">
                <label>单位名称</label>
            </div>
            <div class="equipment-right-select"
                 @click="companyPropShow = true"
                 v-if="userInfo.departsir != '1'">
                <span>{{checkcompany.Name?checkcompany.Name:'请选择'}}</span>
                <i class="iconfont icon-jinru rightmsg"></i>
            </div>
            <div class="equipment-right-select"
                 v-else>
                <span>{{checkcompany.Name}}</span>
            </div>
        </div>
        <div class="form-item form-item-style1">
            <div class="label-title">
                <label>演练方式</label>
            </div>
            <group>
                <popup-picker :data="wayArr"
                              placeholder='请选择'
                              v-model="wayVal"
                              @on-change="onPullingDown"></popup-picker>
            </group>
        </div>
        <div class="form-item form-item-style1">
            <div class="label-title">
                <label>查询开始时间</label>
            </div>
            <group>
                <datetime v-model="startDate"
                          @on-change="onPullingDown"></datetime>
            </group>
        </div>
        <div class="form-item form-item-style1">
            <div class="label-title">
                <label>查询开始时间</label>
            </div>
            <group>
                <datetime v-model="endDate"
                          @on-change="onPullingDown"></datetime>
            </group>
        </div>
        <h3>总数：{{listAllCount}}</h3>
        <noData v-if="lists.length == 0"></noData>
        <vue-better-scroll class="betterscrollWrapper"
                           ref="scroll"
                           :scrollbar="scrollbarObj"
                           :pullDownRefresh="pullDownRefreshObj"
                           :pullUpLoad="pullUpLoadObj"
                           :startY="parseInt(startY)"
                           @pullingDown="onPullingDown"
                           @pullingUp="onPullingUp">
            <ul class="lists">
                <li v-for="(item,index) in lists"
                    :key="index">
                    <router-link :to="{path:'/emergencyTestPlanDetail',query:{detail:JSON.stringify(item)}}">
                        <div>
                            <h5>{{item.PlanTopic}}</h5>
                            <p>{{item.WorkDeptName}}</p>
                        </div>
                        <div class="status">
                            <span>{{item.PlanTime?item.PlanTime.split(' ')[0]:''}}</span>
                            <x-icon type="ios-arrow-right"
                                    size="20"
                                    class="icon-right"
                                    fill="#999"></x-icon>
                        </div>
                    </router-link>
                </li>
            </ul>
        </vue-better-scroll>
        <myMenu></myMenu>
        <activityCompany :selectCompany="selectCompany"
                         :companyPropShow="companyPropShow"></activityCompany>
    </div>
</template>
<script>
import formatDate from '@/utils/formatDate'
import VueBetterScroll from 'vue2-better-scroll'
import myMenu from '@/commonComponents/menu'
import activityCompany from '@/commonComponents/activityCompany'
export default {
    name: 'plan',
    components: {
        VueBetterScroll,
        myMenu,
        activityCompany
    },
    data () {
        return {
            wayData: [],
            wayArr: [['全部']],
            wayVal: ['全部'],
            userInfo: {},
            // dropDown: false
            // 这个配置可以开启滚动条，默认为 false。当设置为 true 或者是一个 Object 的时候，都会开启滚动条，默认是会 fade 的
            scrollbarObj: {
                fade: true
            },
            // 这个配置用于做下拉刷新功能，默认为 false。当设置为 true 或者是一个 Object 的时候，可以开启下拉刷新，可以配置顶部下拉的距离（threshold） 来决定刷新时机以及回弹停留的距离（stop）
            pullDownRefreshObj: {
                threshold: 90,
                stop: 40
            },
            // 这个配置用于做上拉加载功能，默认为 false。当设置为 true 或者是一个 Object 的时候，可以开启上拉加载，可以配置离底部距离阈值（threshold）来决定开始加载的时机
            pullUpLoadObj: {
                threshold: 0,
                txt: {
                    more: '加载更多',
                    noMore: '没有更多数据了'
                }
            },
            startY: 0, // 纵轴方向初始化位置
            scrollToX: 0,
            scrollToY: 0,
            scrollToTime: 700,
            startDate: '',
            endDate: formatDate(),
            pageIndex: 0, // 当前页
            listAllCount: 0, // 总条数
            companyPropShow: false,
            lists: [],
            checkcompany: {
            } //  单位名称
        }
    },
    created () {
        this.userInfo = JSON.parse(localStorage.getItem('userInfo')) || {}
        this.checkcompany = {
            Name: this.userInfo.deptname,
            Id: this.userInfo.deptid
        }
        let newDate = new Date()
        let year = newDate.getFullYear()
        this.startDate = `${year}-01-01`
        this.getExerWay()
        this.onPullingDown()
    },
    methods: {
        onPullingDown () {
            // 模拟下拉刷新
            this.listCount = 0
            this.pageIndex = 0
            this.lists = []
            this.getData()
        },
        onPullingUp () {
            this.pageIndex++
            this.getData()
        },
        selectCompany (item) {
            this.companyPropShow = false
            this.checkcompany = {
                Name: item.deptName,
                Id: item.deptId
            }
            this.onPullingDown()
        },
        getExerWay () {
            let params = {
                'allowPaging': true,
                'business': 'GetExerWay',
                'pageIndex': 1,
                'pageSize': 20,
                'tokenId': '',
                'userId': this.userInfo.userid
            }
            this.$axiosAjax.getConfigJson(params)
                .then((res) => {
                    if (res.data.code === 0) {
                        this.wayData = res.data.data
                        this.wayData.forEach((item) => {
                            this.wayArr[0].push(item.Content)
                        })
                    }
                }).catch((response) => {
                })
        },
        getData () { // 获取通知公告
            var params = {
                'allowPaging': true,
                'business': 'GetExerPlanList',
                'data': {
                    'DepartId': this.checkcompany.Id, // 单位Id
                    'EndTime': this.endDate, // 结束时间
                    'ExerWay': '', // 演练方式
                    'StartTime': this.startDate// 开始时间
                },
                'pageIndex': this.pageIndex,
                'pageSize': 10,
                'userId': this.userInfo.userid
            }
            for (let i = 0; i < this.wayData.length; i++) {
                if (this.wayData[i].Content === this.wayVal[0]) {
                    params.data.ExerWay = this.wayData[i].CodeName
                    break
                }
            }
            this.$axiosAjax.getConfigJson(params)
                .then((res) => {
                    if (res.data.code === 0) {
                        this.lists = this.lists.concat(res.data.data)
                        this.listAllCount = res.data.count
                        this.listCount = this.lists.length
                    }
                    if (this.listCount < this.listAllCount) {
                        this.$refs.scroll.forceUpdate(true)
                    } else {
                        this.$refs.scroll.forceUpdate(false)
                    }
                }).catch((response) => {
                })
        }
    }
}
</script>
<style lang="less" scoped>
h3 {
    height: 40px;
    line-height: 40px;
    color: #999;
    font-size: 14px;
    background: #ebeef2;
    padding-right: 20px;
    text-align: right;
}
.betterscrollWrapper {
    position: absolute;
    top: 320px;
    left: 0;
    right: 0;
    bottom: 0;
}
.lists {
    padding-left: 20px;
    a {
        display: flex;
        justify-content: space-between;
        align-items: center;
        padding: 14px 20px 14px 0;
        border-bottom: 1px solid #efeff4;
    }
    h5 {
        line-height: 18px;
        color: #333;
        font-size: 14px;
    }
    p {
        font-size: 14px;
        color: #999;
        line-height: 18px;
    }
    .status {
        display: flex;
        align-items: center;
        span {
            font-size: 12px;
            color: #999;
        }
    }
}
</style>
